package com.xm.core.service;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.mdp.core.api.CacheHKVService;
import com.mdp.core.service.BaseService;
import com.xm.core.entity.XmRptData;
import com.xm.core.mapper.XmRptDataMapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;
import java.util.Map;
/**
 * 父类已经支持增删改查操作,因此,即使本类什么也不写,也已经可以满足一般的增删改查操作了.<br> 
 * 组织 com  顶级模块 xm 大模块 core 小模块 <br>
 * 实体 XmRptData 表 xm_rpt_data 当前主键(包括多主键): id; 
 ***/
@Service("xm.core.xmRptDataService")
public class XmRptDataService extends BaseService<XmRptDataMapper,XmRptData> {
	static Logger logger =LoggerFactory.getLogger(XmRptDataService.class);
	@Autowired
	CacheHKVService<XmRptData> cacheHKVService;

	/**
	 * 自定义查询，支持多表关联
	 * @param page 分页条件
	 * @param ew 一定要，并且必须加@Param("ew")注解
	 * @param ext 如果xml中需要根据某些值进行特殊处理，可以通过这个进行传递，非必须，注解也可以不加
	 * @return
	 */
	public List<Map<String,Object>> selectListMapByWhere(IPage page, QueryWrapper ew, Map<String,Object> ext){
		return baseMapper.selectListMapByWhere(page,ew,ext);
	}

	public XmRptData getFromCacheFirst(String id){
		String spaceKey=XmRptDataService.class.getSimpleName();
		XmRptData xmRptData=cacheHKVService.get(spaceKey,id);
		if(xmRptData==null){
			xmRptData = getById(id);
			if(xmRptData!=null){
				cacheHKVService.put(spaceKey,id,xmRptData);
			}
		}
		return xmRptData;

	}
}

